package co.inventario.modelo.fachada;

import java.sql.SQLException;
import java.util.ArrayList;

import co.inventario.entidad.ClienteDTO;
import co.inventario.modelo.negocio.ClienteNegocio;
import co.inventario.transversal.DAOFactorySQLServer;

public class ClienteFachada {

	public void crear(ClienteDTO clienteDTO) throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		ClienteNegocio clienteNegocio = new ClienteNegocio();
		try {
			clienteNegocio.crear(clienteDTO, daoFactorySQLServer.obtenerConexion());
			daoFactorySQLServer.confirmarTransaccion();
		} catch (SQLException exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw new Exception("Se ha presentado un problema intentando crear el cliente.");
		} catch (Exception exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
	}

	public void actualizar(ClienteDTO clienteDTO) throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		ClienteNegocio clienteNegocio = new ClienteNegocio();
		try {
			clienteNegocio.actualizar(clienteDTO, daoFactorySQLServer.obtenerConexion());
			daoFactorySQLServer.confirmarTransaccion();
		} catch (SQLException sqlException) {
			daoFactorySQLServer.cancelarTransaccion();
			throw new Exception("Se ha presentado un problema intentando actualizar el cliente.");
		} catch (Exception exception) {
			daoFactorySQLServer.cancelarTransaccion();
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
	}

	public ArrayList<ClienteDTO> consultarTodo() throws Exception {
		DAOFactorySQLServer daoFactorySQLServer = new DAOFactorySQLServer();
		ClienteNegocio clienteNegocio = new ClienteNegocio();
		ArrayList<ClienteDTO> clienteDTOLista = null;
		try {
			clienteDTOLista = clienteNegocio.consultarTodo(daoFactorySQLServer.obtenerConexion());
		} catch (SQLException exception) {
			throw new Exception("Se ha presentado un problema intentando consultar los clientes.");
		} catch (Exception exception) {
			throw exception;
		} finally {
			daoFactorySQLServer.cerrarConexion();
		}
		return clienteDTOLista;
	}
}
